-
Notifications
You must be signed in to change notification settings - Fork 866
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Remove SecurityManager layer #7928
base: master
Are you sure you want to change the base?
Conversation
Not too much against SM removal. A few assorted comments, just to list what I know of. None of these necessarily means we need to replace SM, but it is something we are loosing.
|
Thanks @mbien Following the Slack conversation on this I've also been running NetBeans a lot with
Sensitive in what way? There are numerous ways that code running in the IDE VM, or even in an external process, can cause the IDE to exit (not to mention any other havoc). I still agree with Alan Bateman's comment on the enhancement request for adding an API to intercept exit - https://bugs.openjdk.org/browse/JDK-8199704 - "There has been several APIs prototyped around this and the conclusion each time is that it probably isn't the right thing to do. If ant or some other task runner is running a task that is hostile to running embedded/in-process then it should be launched into their own process/VM." IMO the benefits of intercepting System::exit are slight in comparison to the complexity introduced, were this the only reason for an agent ...
The agent approach doesn't use the clipboard swap trick to implement this AFAIK. 8114562 The clipboard aspect of this is actually the aspect that concerns me the most. At the same time, given all the clipboard issues on Windows, removing all hacks might at least prove it's not our fault! 😄
With a disabled SM the paste from history is partly broken. It's possibly worth considering what the point of this feature is. If it's external and in-editor text, then that might be achievable without clipboard listening. There are of course now some events fired by the clipboard, but I assume not covering everything we want. OTOH, with the custom clipboard disabled, certain pasting (I noticed file paths particularly) now functions better! |
You can of course replace the launcher in the workflow dev build with the launcher built from this PR at https://github.com/apache/netbeans/actions/runs/11605258427 I wonder if we can find a way to do this automatically for dev builds that change the launcher code??? 🤔 |
JFR will write events for both, halt and exit. the java.lang.Runtime logger unfortunately only logs exit. I asked on the JDK list a few weeks ago, there was also a proposal to log on halt too - but it was decided to not implement it there specifically due to the risk of the callback into application code (logger) which could fail for whatever reason. While debugging, IMO: an annotation processor calling halt, would be as broken as a annotation processor trying figure out your system password. Malicious or not - dependencies like that are filtered out by the java ecosystem, library supply chain reviews etc. You should not blindly use libraries you don't know - only protecting against exit/halt gives only a false sense of safety - a disappearing JVM is the smallest problem if you truly don't trust the code you execute.
I feared the same. However, it seems to work fine with one slight change in behavior: Copy from the editor will only appear in the list after focus loss or after the next copy event (paste works correctly though), everywhere else it appears right away. So there seems to be a special case for copy from editor specifically - this might be also connected to the bug, see comment #7051 (comment) |
update:
|
4865bf5
to
c9c954d
Compare
|
a7defcb
to
34d4a34
Compare
All tests green: https://github.com/apache/netbeans/actions/runs/12401186185 The only exception are the edit: nb-javac PR is now merged to master, removed staged javac and rebased this PR again |
javac.source=1.8 | ||
javac.release=11 |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
note to self: this bumps bootstrap to 11 to have access to the StackWalker
API.
this should be fine since Main
is compiled separately, so the warning dialogs will still show up when launched on older JDKs:
netbeans/platform/o.n.bootstrap/build.xml
Lines 32 to 40 in 33cdacf
<target name="rebuild-main" unless="main.up.to.date"> | |
<mkdir dir="${build.classes.dir}"/> | |
<delete file="${build.classes.dir}/org/netbeans/Main.class"/> | |
<javac srcdir="${src.dir}" destdir="${build.classes.dir}" debug="${build.compiler.debug}" debuglevel="${build.compiler.debuglevel}" deprecation="${build.compiler.deprecation}" optimize="${build.compiler.optimize}" source="1.8" target="1.8" includeantruntime="false"> | |
<classpath refid="cp"/> | |
<include name="org/netbeans/Main.java"/> | |
<compilerarg line="${javac.compilerargs}"/> | |
</javac> | |
</target> |
- remove TopSecuirityManager and SecMan - remove security manager JVM flags from build and config - remove NBClipboard activation tests - implement getStack() using StackWalker - enable system exit logging
Hey @mbien , should we also delete |
@BradWalker this PR already removes that file, or do you mean something else? I can find only one allow.java |
Now the launcher is updated to remove the hardcoded @lahodaj thoughts on this? Seems similar to the javavscode PR you linked above? |
Well, I'm running a NetBeans development build on Windows 10 using OpenJDK 24 right now and it seems to be running fine so far. From the I deleted the JVM options: -J--add-opens=java.base/java.security=ALL-UNNAMED-J-Djava.security.manager=allowAnd I added the JVM option: -J-DTopSecurityManager.disable=true |
please note that we have two discussion threads on the dev list. The first is about the SM removal roadmap itself, the second about the concrete implementation of the removal. We have also two proposals for that. Lets not discuss
edit: opened #8169 and moving milestone to NB26 for this PR here |
import java.util.logging.LoggingPermission; | ||
import org.openide.util.Lookup; | ||
import org.openide.util.WeakSet; | ||
|
||
/** NetBeans security manager implementation. | ||
* @author Ales Novak, Jesse Glick |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think my name can be removed now that it has been gutted. 😁
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
it would be rude to remove author information! :) This class has only one method left, we probably should move it somewhere else in another pass - I kept it minimal for now.
my current hope is to integrate this (or an alternative) early in the NB 26 cycle, so that we can begin testing on the upper bound JDK 24. (#8169 would be for NB 25) NB 25 might be the first release for a long time where nb-javac version > validated upper bound via CI - but lets not keep it that way for longer periods. |
JDK 24 on the horizon we will have to find a solution for the upcoming removal of the deprecated
SecurityManager
mechanism.JEP 486 is a candidate for JDK 24, PR is here openjdk/jdk#21498 (
still openmerged, in build 24+), once #8037 is merged we can run CI on 24ea too.This PR is an alternative to #3386 and proposes to remove the SM layer entirely, trying to avoid additional complexity of a tracking agent.
To simulate this, I am running NB 23 with
-DTopSecurityManager.disable=true -Djava.lang.Runtime.level=FINE
for severalweeksmonth now without issues, this PR goes one step further and removes the SM layer for a test build - which I tested too.What is SM used for? Why could we likely simply remove it?
System exit blocking:
-J-Djava.lang.Runtime.level=FINE
(will log full stack trace) and also via JFR'sjdk.Shutdown
eventEXIT_ON_CLOSE
System.exit(0)
) but nothing did actually exit NBswing clipboard swap:
sun.awt.AppContext
and writeTransferHandler#SandboxClipboardKey
using reflection, which was only read by Swing if a SM blocked access to the system clipboard (!)--add-opens
hereFile IO tracking:
Tracking calls to Unsafe:
--sun-misc-unsafe-memory-access=deny
Tracking property access:
Tests:
-> I don't think we actually need the SM layer anymore. This gives us an opportunity to remove a layer without further complicating things with an agent requirement for everything (launcher, tests, archetypes etc).
The agent rewrites bytecode by hand(!) to avoid having to bundle ASM, this could be likely solved by shading ASM till JDK 23 and using the multi-release mechanism + classfile API for 24+ (now final) but this is all extra maintenance cost which we should try to avoid if possible.
Bytecode rewriting can cause followup issues e,g jumping out of methods during debugging sessions without seeing the reason for it in the source.
I do think the agent impl is actually pretty cool but I don't think everything what can be added, should be added if it is avoidable. (also please note that back then NB was still stuck on JDK 8)
this is just a draft - don't panic. This likely will need to be discussed on the mailing list anyway (thread).
But feel free to give the dev build it a try. (
the windows launcher might still break things since it has to be build separately unfortunatelydone)